/**
 * @Description: 首页活动配置
 * @author ourslookAdmin
 * @date 2019-04-26 14:38:59
 */
import React, { Fragment } from 'react';
import Modal from 'drag-modal';
import {
  Button,
  Card,
  Checkbox,
  Col,
  Divider,
  Form,
  Input,
  InputNumber,
  Radio,
  Row,
  Select,
  Spin,
  Tag,
  TreeSelect,
  BackTop,
  Upload,
  Icon,
  ChromePicker,
  message,
  Tooltip,
  Switch,
} from 'antd/lib/index';

import InputColor from 'react-input-color';
import { formatMessage, FormattedMessage } from 'umi/locale';
import 'antd/dist/antd.css';
import PropTypes from 'prop-types';
import { connect } from 'dva';
import { requestLists, requestPromise } from '@/utils/request';
import PageHeaderWrapper from '@/components/PageHeaderWrapper';
import { Pie } from '@/components/Charts';
import numeral from 'numeral';
import BaseForm from '../../../components/ourslook/BaseForm';
import ETable from '../../../components/ourslook/ETable';
import { getWebPath } from '../../../utils/request';
import uiUtils, { hasPermission, rulesReg, rulesRemote } from '../../../utils/uiUtils';
import styles from '../../../utils/ourslook.less';

import coming from '@/decorator/coming';

const FormItem = Form.Item;
const Option = Select.Option;
const RadioGroup = Radio.Group;
const TextArea = Input.TextArea;
const Password = Input.Password;
const CheckboxGroup = Checkbox.Group;
const isTrue = true;
const isFalse = false;

const getValue = obj =>
  Object.keys(obj)
    .map(key => obj[key])
    .join(',');

// @coming({title: '精彩即将呈现！', value: Date.now() + 1000 * 60 * 60 * 24 * 2})
@connect(() => ({}))
class ThirdOrder extends React.Component {
  params = {
    page: 1,
    limit: 10,
  };

  formItemLayout = {
    labelCol: { span: 5 },
    wrapperCol: { span: 19 },
  };

  /**
   * https://ant-design.gitee.io/components/table-cn/
   *
   * 需要指定 column 的 width 属性，否则列头和内容可能不对齐。（必须留一列不设宽度或者minWidth以适应弹性布局）
   * 建议指定 scroll.x 为大于表格宽度的固定值或百分比。注意，且非固定列宽度之和不要超过 scroll.x, 一般无table正常展开的宽度
   * 未知长度字段或者字符特别多的字段不要放置在列表
   */
  columns = [
    {
      title: '',
      width: 30,
      align: 'center',
      fixed: 'left',
      render: (value, record, index) => index + 1,
    },
    { title: '平台名称', dataIndex: 'platformName', width: 150, align: 'center', sorter: false },
    { title: '商品名称', dataIndex: 'productName', width: 150, align: 'center', sorter: false },
    { title: '订单数量', dataIndex: 'orderNum', align: 'right', sorter: false },
    {
      title: '订单总金额',
      dataIndex: 'orderTotalPrice',
      width: 100,
      align: 'right',
      sorter: false,
      render: (value, record, index) => {
        if (value !== null && value !== undefined) {
          return `￥${numeral(value).format('0,0.00')}`;
        }
        return '-';
      },
    },
  ];

  constructor(props) {
    super(props);
    this.state = {
      showList: 1, //1:显示列表、2:显示新增
      formList: ThirdOrder.getFormList(),
      selectedRows: [],
      selectedIds: [],
      selectedIndexs: [],
      editModalTitle: null,
      editModalType: null,
      editModel: null,
      editModelConfirmLoading: false,
      //其他属性下面书写
      loading: false,
    };
  }

  // 筛选条件
  static getFormList = () => [
    {
      type: 'SELECT',
      field: 'searchType',
      label: '筛选类型',
      list: [{ id: '', name: '筛选类型' }, { id: '1', name: '平台' }, { id: '2', name: '商品' }],
    },
    {
      type: 'INPUT',
      field: 'productName',
      label: '商品名称',
      placeholder: '商品名称',
    },
    {
      type: 'DATE_RANGE',
      field: 'timePlaceOrder',
      label: '下单时间',
      placeholder: ['下单时间', '结束时间'],
    },
    // {
    //   type: 'INPUT',
    //   field: 'title',
    //   label: '标题',
    //   placeholder: '标题',
    // },
  ];

  componentDidMount() {
    this.requestList();
  }

  componentWillUnmount() {}

  /**
   * 根据 formItem field 取值 查找formItem
   * @param formItemField obj的field字段
   * @returns 一个对象
   */
  findFormListItemByField = formItemField =>
    this.state.formList.find((value, index, array) => value.field === formItemField);

  query = fieldParams => {
    this.params = JSON.parse(JSON.stringify(Object.assign(this.params, fieldParams)));
    this.requestList();
  };

  add = () => {
    this.setState({
      editModalType: 'add',
      editModalTitle: formatMessage({ id: 'ours.curd.list.create' }), //创建
      editModel: {
        type: '',
        enable: isTrue,
        bugColor: '#5e72e4',
      },
      showList: 2,
    });
  };

  update = () => {
    const { selectedRows, selectedIds, selectedIndexs } = this.state;
    if (!selectedRows) {
      uiUtils.showAlert(formatMessage({ id: 'ours.curd.show-alert.select-please' }));
      return;
    }
    if (selectedRows.length > 1) {
      uiUtils.showAlert(formatMessage({ id: 'ours.curd.show-alert.select-one-please' }));
      return;
    }
    selectedRows[0].sort = `${selectedRows[0].sort}`;
    this.setState({
      editModalType: 'update',
      editModalTitle: <FormattedMessage id="ours.curd.list.edit" defaultMessage="编辑" />,
      editModel: JSON.parse(JSON.stringify(selectedRows[0])),
      showList: 2,
    });
    this.getInfo(selectedRows[0].id);
  };

  view = () => {
    const { selectedRows, selectedIds, selectedIndexs } = this.state;
    if (!selectedRows) {
      uiUtils.showAlert(formatMessage({ id: 'ours.curd.show-alert.select-please' }));
      return;
    }
    if (selectedRows.length > 1) {
      uiUtils.showAlert(formatMessage({ id: 'ours.curd.show-alert.select-one-please' }));
      return;
    }
    this.setState({
      editModalType: 'view',
      editModalTitle: <FormattedMessage id="ours.curd.list.info" defaultMessage="查看" />,
      editModel: selectedRows[0],
      showList: 2,
    });
    this.getInfo(selectedRows[0].id);
  };

  del = () => {
    const selectedRows = this.state.selectedRows;
    const ids = [];
    for (let i = 0; i < selectedRows.length; i += 1) {
      ids.push(selectedRows[i].id);
    }

    uiUtils.showConfirm(formatMessage({ id: 'ours.curd.show-alert.confirm-delete' }), () => {
      this.setState({
        loading: true,
      });
      requestPromise(`${getWebPath()}bushomenavi/delete`, {
        method: 'POST',
        body: ids,
      }).then(res => {
        this.setState({
          loading: false,
        });
        if (res && res.code === 0) {
          uiUtils.showMessage(
            formatMessage({ id: 'ours.curd.show-alert.operate-success' }),
            'success'
          );
          this.requestList();
        }
      });
    });
  };

  saveOrUpdate = () => {
    const editModalType = this.state.editModalType;
    //不能双向绑定，这里只能原对象、新对象进行合并.
    const busHomeNavi = Object.assign(
      this.state.editModel,
      this.editForm.props.form.getFieldsValue()
    );

    if (busHomeNavi.bugColor != null) {
      busHomeNavi.bugColor = busHomeNavi.bugColor.hex;
    }
    this.editForm.props.form.validateFieldsAndScroll((err, values) => {
      if (!err) {
        // submit the values
        const url = busHomeNavi.id == null ? '/bushomenavi/save' : '/bushomenavi/update';
        //对象删除一个属性
        //delete busHomeNavi.xxxxPros;
        this.setState({
          editModelConfirmLoading: true,
        });
        requestPromise(getWebPath() + url, {
          method: 'POST',
          body: busHomeNavi,
        }).then(res => {
          this.setState({
            editModelConfirmLoading: false,
          });
          if (res && res.code === 0) {
            uiUtils.showMessage(
              formatMessage({ id: 'ours.curd.show-alert.operate-success' }),
              'success'
            );
            this.setState({
              showList: 1,
            });

            //新增重新置为第一页
            if (!busHomeNavi.id) {
              this.params.page = 1;
            }
            this.requestList();
          }
        });
      }
      // else{
      //   this.showInfo();
      // }
    });
  };

  getInfo = id => {};

  setStateByTableColume = (record, index) => {
    this.state = {
      ...this.state,
      selectedRows: [record],
      selectedIds: [record.id],
      selectedIndexs: [index],
    };
  };

  operateByIds = status => {};

  //========其他所有的处理方法，请在按照约定进行处理==========

  /**
   * 表格 筛选和排序 回调
   */
  filtersSorterChange = tableParams => {
    this.params = JSON.parse(JSON.stringify(Object.assign(this.params, tableParams)));
    this.requestList();
  };

  requestList = () => {
    this.setState({ list: null });
    requestLists(this, `${getWebPath()}orderimportplatform/getOrderNum`, this.params);
  };

  vShow = showListNum => ({ display: this.state.showList === showListNum ? 'block' : 'none' });

  render() {
    const style = {
      style: {
        marginLeft: 10,
        marginTop: 10,
      },
      disabled: this.state.selectedIndexs.length <= 0,
    };
    const { searchType } = this.params;
    const { list } = this.state;
    if (list !== undefined && list !== null) {
      list.forEach(d => {
        if (searchType !== undefined && searchType === '2') {
          d.x = d.productName;
        } else {
          d.x = d.platformName;
        }
        d.y = d.orderNum;
      });
    }

    /* eslint-disable react/jsx-no-bind */
    return (
      <PageHeaderWrapper title="">
        <Card
          bordered={false}
          style={{ ...this.vShow(1) }}
          className={styles.oursCard}
          bodyStyle={{ padding: '20px' }}
        >
          <BaseForm
            formList={this.state.formList}
            loading={this.state.loading}
            filterSubmit={this.query}
          />

          {/*<Fragment>*/}
          {/*  <Button*/}
          {/*    type="primary"*/}
          {/*    icon="plus"*/}
          {/*    onClick={this.add}*/}
          {/*    hidden={!hasPermission('bushomenavi:save')}*/}
          {/*  >*/}
          {/*    <FormattedMessage id="ours.curd.list.add" defaultMessage="新增" />*/}
          {/*  </Button>*/}
          {/*  <Button*/}
          {/*    type="primary"*/}
          {/*    icon="edit"*/}
          {/*    {...style}*/}
          {/*    onClick={this.update}*/}
          {/*    hidden={!hasPermission('bushomenavi:update')}*/}
          {/*  >*/}
          {/*    <FormattedMessage id="ours.curd.list.update" defaultMessage="修改" />*/}
          {/*  </Button>*/}
          {/*  <Button*/}
          {/*    type="primary"*/}
          {/*    icon="info-circle"*/}
          {/*    {...style}*/}
          {/*    onClick={this.view}*/}
          {/*    hidden={!hasPermission('bushomenavi:info')}*/}
          {/*  >*/}
          {/*    <FormattedMessage id="ours.curd.list.info" defaultMessage="查看" />*/}
          {/*  </Button>*/}
          {/*  <Button*/}
          {/*    type="danger"*/}
          {/*    icon="delete"*/}
          {/*    {...style}*/}
          {/*    onClick={this.del}*/}
          {/*    hidden={!hasPermission('bushomenavi:delete')}*/}
          {/*  >*/}
          {/*    <FormattedMessage id="ours.curd.list.delete" defaultMessage="删除" />*/}
          {/*  </Button>*/}
          {/*</Fragment>*/}

          <div style={{ width: '50%', float: 'left' }}>
            <ETable
              onSelectRow={uiUtils.onSelectRow.bind(this)}
              primaryKey="id"
              rowSelection={null}
              selectedRows={this.state.selectedRows}
              selectedIds={this.state.selectedIds}
              selectedIndexs={this.state.selectedIndexs}
              onChange={this.filtersSorterChange}
              columns={this.columns}
              dataSource={this.state.list}
              pagination={this.state.pagination}
              loading={this.state.loading}
              scroll={{ x: 400 }}
            />
          </div>
          <div style={{ width: '50%', float: 'left' }}>
            <Pie
              hasLegend
              subTitle="订单数量"
              total={() =>
                `${
                  list === undefined || list === null
                    ? 0
                    : list.reduce((pre, now) => now.y + pre, 0)
                }件`
              }
              data={list}
              valueFormat={value => `${value}件`}
              height={248}
              lineWidth={4}
            />
          </div>
        </Card>

        <BackTop />

        <Spin spinning={this.state.editModelConfirmLoading} delay={10}>
          {//返回null,这里对不用的组件进行销毁
          this.state.showList === 1 ? null : (
            <Card
              title={this.state.editModalTitle}
              bordered={false}
              actions={[
                <div>
                  <React.Fragment>
                    <Button
                      type="primary"
                      hidden={this.state.editModalType === 'view'}
                      style={{ marginRight: '18px' }}
                      onClick={this.saveOrUpdate}
                    >
                      <FormattedMessage id="ours.curd.add.save" defaultMessage="保存" />
                    </Button>
                    <Button
                      style={{ marginRight: '18px' }}
                      onClick={() => {
                        this.editForm.props.form.resetFields();
                        this.setState({ showList: 1 });
                      }}
                    >
                      <FormattedMessage id="ours.curd.add.back" defaultMessage="返回" />
                    </Button>
                  </React.Fragment>
                </div>,
              ]}
              style={{ ...this.vShow(2) }}
              bodyStyle={{ padding: '20px' }}
              ref={node => {
                this.container = node;
              }}
            >
              <EditForm
                type={this.state.editModalType}
                model={this.state.editModel}
                loadingCallback={loading => {
                  if (this.state.editModelConfirmLoading !== loading) {
                    this.setState({
                      editModelConfirmLoading: loading,
                    });
                  }
                }}
                wrappedComponentRef={inst => {
                  this.editForm = inst;
                }}
              />
            </Card>
          )}
        </Spin>
      </PageHeaderWrapper>
    );
  }
}

export default ThirdOrder;

/**
 *  新增、编辑、复制、查看的Form
 */

/* eslint react/no-multi-comp:0 */
class EditForm extends React.Component {
  static propTypes = {
    type: PropTypes.string, //form类型，可选值：add（增加）、update（修改）、copy（复制）、view（查看）、
    model: PropTypes.object, //数据模型model，对应后台的model
  };

  static defaultProps = {
    type: '', //表单布局数组
    model: null,
  };

  constructor(props) {
    super(props);

    this.state = {};
  }

  /**
   * 生命周期-属性发生变化...componentWillReceiveProps
   * 这里的nextProps，可以获取到所有的属性。
   * 目前没用，因为 dialog 每次都被销毁了
   */
  componentWillReceiveProps(nextProps) {}

  getPropsByKey = prop => {
    const model = this.props.model || {};
    const finalModel = Object.assign(model, this.props.form.getFieldsValue());
    return finalModel[prop];
  };

  render() {
    const type = this.props.type; //编辑是：新增（add）、编辑(edit)、复制(copy)、还是查看(view)
    const model = this.props.model || {};
    const {
      form,
      form: { getFieldDecorator, getFieldValue, setFieldsValue },
    } = this.props;
    const formItemLayout = {
      labelCol: { span: 5 },
      wrapperCol: { span: 18 }, //5+19=24,少一个栅格
    };
    const colSpanLayout = { md: 12, sm: 24 }; //每一col跨?列
    const rowGutterPxLayout = { md: 24, sm: 16 }; //col之间的间隔?px
    const inputCodeDisabled = {
      disabled: type === 'update',
    };
    const uploadButton = (
      <div>
        <Icon type="plus" />
        <div className="ant-upload-text">上传</div>
      </div>
    );

    const imageUrl = this.state.imageUrl;

    //校验文档：https://ant.design/components/form-cn/#%E6%A0%A1%E9%AA%8C%E8%A7%84%E5%88%99
    return (
      <Form layout="horizontal">
        <Row gutter={{ ...rowGutterPxLayout }} />
      </Form>
    );
  }
}

/* eslint-disable no-class-assign */
//无更多的绑定， 请用 @Form.create() 注解替换
EditForm = Form.create({})(EditForm);
